//给你一个整数数组 nums ，数组中的元素 互不相同 。返回该数组所有可能的子集（幂集）。 
//
// 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。 
//
// 
//
// 示例 1： 
//
// 
//输入：nums = [1,2,3]
//输出：[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]
// 
//
// 示例 2： 
//
// 
//输入：nums = [0]
//输出：[[],[0]]
// 
//
// 
//
// 提示： 
//
// 
// 1 <= nums.length <= 10 
// -10 <= nums[i] <= 10 
// nums 中的所有元素 互不相同 
// 
//
// Related Topics 位运算 数组 回溯 👍 2067 👎 0


import java.util.ArrayList;
import java.util.List;

//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public List<List<Integer>> subsets(int[] nums) {
        List<List<Integer>> result=new ArrayList<>();
        List<Integer> tem=new ArrayList<>();
        backTracking(0,nums,result,tem);

        return  result;

    }
    public void backTracking(int index ,int[] nums, List<List<Integer>> result,  List<Integer> tem){
        result.add(new ArrayList<>(tem));
        if(index>=nums.length){
            return;
        }
        for (int i = index; i < nums.length; i++) {
            tem.add(nums[i]);
            backTracking(i+1,nums,result,tem);
            tem.remove(tem.size()-1);
        }

    }
}
//leetcode submit region end(Prohibit modification and deletion)
